home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Personal Computer World 2009 February
/
PCWFEB09.iso
/
Software
/
Resources
/
Chat & Communication
/
Digsby build 37
/
digsby_setup.exe
/
lib
/
PIL
/
TiffImagePlugin.pyo
(
.txt
)
< prev
next >
Wrap
Python Compiled Bytecode
|
2008-10-13
|
20KB
|
696 lines
# Source Generated with Decompyle++
# File: in.pyo (Python 2.5)
__version__ = '1.3.5'
import Image
import ImageFile
import ImagePalette
import array
import string
import sys
try:
if sys.byteorder == 'little':
byteorder = 'II'
else:
byteorder = 'MM'
except AttributeError:
if ord(array.array('i', [
1]).tostring()[0]):
byteorder = 'II'
else:
byteorder = 'MM'
except:
ord(array.array('i', [
1]).tostring()[0])
def il16(c, o = 0):
return ord(c[o]) + (ord(c[o + 1]) << 8)
def il32(c, o = 0):
return ord(c[o]) + (ord(c[o + 1]) << 8) + (ord(c[o + 2]) << 16) + (ord(c[o + 3]) << 24)
def ol16(i):
return chr(i & 255) + chr(i >> 8 & 255)
def ol32(i):
return chr(i & 255) + chr(i >> 8 & 255) + chr(i >> 16 & 255) + chr(i >> 24 & 255)
def ib16(c, o = 0):
return ord(c[o + 1]) + (ord(c[o]) << 8)
def ib32(c, o = 0):
return ord(c[o + 3]) + (ord(c[o + 2]) << 8) + (ord(c[o + 1]) << 16) + (ord(c[o]) << 24)
IMAGEWIDTH = 256
IMAGELENGTH = 257
BITSPERSAMPLE = 258
COMPRESSION = 259
PHOTOMETRIC_INTERPRETATION = 262
FILLORDER = 266
IMAGEDESCRIPTION = 270
STRIPOFFSETS = 273
SAMPLESPERPIXEL = 277
ROWSPERSTRIP = 278
STRIPBYTECOUNTS = 279
X_RESOLUTION = 282
Y_RESOLUTION = 283
PLANAR_CONFIGURATION = 284
RESOLUTION_UNIT = 296
SOFTWARE = 305
DATE_TIME = 306
ARTIST = 315
PREDICTOR = 317
COLORMAP = 320
EXTRASAMPLES = 338
SAMPLEFORMAT = 339
JPEGTABLES = 347
COPYRIGHT = 33432
IPTC_NAA_CHUNK = 33723
PHOTOSHOP_CHUNK = 34377
COMPRESSION_INFO = {
1: 'raw',
2: 'tiff_ccitt',
3: 'group3',
4: 'group4',
5: 'tiff_lzw',
6: 'tiff_jpeg',
7: 'jpeg',
32771: 'tiff_raw_16',
32773: 'packbits' }
OPEN_INFO = {
(0, 1, 1, (1,), ()): ('1', '1;I'),
(0, 1, 2, (1,), ()): ('1', '1;IR'),
(0, 1, 1, (8,), ()): ('L', 'L;I'),
(0, 1, 2, (8,), ()): ('L', 'L;IR'),
(1, 1, 1, (1,), ()): ('1', '1'),
(1, 1, 2, (1,), ()): ('1', '1;R'),
(1, 1, 1, (8,), ()): ('L', 'L'),
(1, 1, 1, (8, 8), (2,)): ('LA', 'LA'),
(1, 1, 2, (8,), ()): ('L', 'L;R'),
(1, 1, 1, (16,), ()): ('I;16', 'I;16'),
(1, 2, 1, (16,), ()): ('I;16S', 'I;16S'),
(1, 2, 1, (32,), ()): ('I', 'I;32S'),
(1, 3, 1, (32,), ()): ('F', 'F;32F'),
(2, 1, 1, (8, 8, 8), ()): ('RGB', 'RGB'),
(2, 1, 2, (8, 8, 8), ()): ('RGB', 'RGB;R'),
(2, 1, 1, (8, 8, 8, 8), (0,)): ('RGBX', 'RGBX'),
(2, 1, 1, (8, 8, 8, 8), (1,)): ('RGBA', 'RGBa'),
(2, 1, 1, (8, 8, 8, 8), (2,)): ('RGBA', 'RGBA'),
(2, 1, 1, (8, 8, 8, 8), (999,)): ('RGBA', 'RGBA'),
(3, 1, 1, (1,), ()): ('P', 'P;1'),
(3, 1, 2, (1,), ()): ('P', 'P;1R'),
(3, 1, 1, (2,), ()): ('P', 'P;2'),
(3, 1, 2, (2,), ()): ('P', 'P;2R'),
(3, 1, 1, (4,), ()): ('P', 'P;4'),
(3, 1, 2, (4,), ()): ('P', 'P;4R'),
(3, 1, 1, (8,), ()): ('P', 'P'),
(3, 1, 1, (8, 8), (2,)): ('PA', 'PA'),
(3, 1, 2, (8,), ()): ('P', 'P;R'),
(5, 1, 1, (8, 8, 8, 8), ()): ('CMYK', 'CMYK'),
(6, 1, 1, (8, 8, 8), ()): ('YCbCr', 'YCbCr'),
(8, 1, 1, (8, 8, 8), ()): ('LAB', 'LAB') }
PREFIXES = [
'MM\x00*',
'II*\x00',
'II\xbc\x00']
def _accept(prefix):
return prefix[:4] in PREFIXES
class ImageFileDirectory:
def __init__(self, prefix = 'II'):
self.prefix = prefix[:2]
if self.prefix == 'MM':
self.i16 = ib16
self.i32 = ib32
elif self.prefix == 'II':
self.i16 = il16
self.i32 = il32
self.o16 = ol16
self.o32 = ol32
else:
raise SyntaxError('not a TIFF IFD')
self.reset()
def reset(self):
self.tags = { }
self.tagdata = { }
self.next = None
def keys(self):
return self.tagdata.keys() + self.tags.keys()
def items(self):
items = self.tags.items()
for tag in self.tagdata.keys():
items.append((tag, self[tag]))
return items
def __len__(self):
return len(self.tagdata) + len(self.tags)
def __getitem__(self, tag):
try:
return self.tags[tag]
except KeyError:
(type, data) = self.tagdata[tag]
(size, handler) = self.load_dispatch[type]
self.tags[tag] = data = handler(self, data)
del self.tagdata[tag]
return data
def get(self, tag, default = None):
try:
return self[tag]
except KeyError:
return default
def getscalar(self, tag, default = None):
try:
value = self[tag]
if len(value) != 1:
if tag == SAMPLEFORMAT:
raise KeyError
raise ValueError, 'not a scalar'
return value[0]
except KeyError:
if default is None:
raise
return default
def has_key(self, tag):
if not self.tags.has_key(tag):
pass
return self.tagdata.has_key(tag)
def __setitem__(self, tag, value):
if type(value) is not type(()):
value = (value,)
self.tags[tag] = value
load_dispatch = { }
def load_byte(self, data):
l = []
for i in range(len(data)):
l.append(ord(data[i]))
return tuple(l)
load_dispatch[1] = (1, load_byte)
def load_string(self, data):
if data[-1:] == '\x00':
data = data[:-1]
return data
load_dispatch[2] = (1, load_string)
def load_short(self, data):
l = []
for i in range(0, len(data), 2):
l.append(self.i16(data, i))
return tuple(l)
load_dispatch[3] = (2, load_short)
def load_long(self, data):
l = []
for i in range(0, len(data), 4):
l.append(self.i32(data, i))
return tuple(l)
load_dispatch[4] = (4, load_long)
def load_rational(self, data):
l = []
for i in range(0, len(data), 8):
l.append((self.i32(data, i), self.i32(data, i + 4)))
return tuple(l)
load_dispatch[5] = (8, load_rational)
def load_float(self, data):
a = array.array('f', data)
if self.prefix != byteorder:
a.byteswap()
return tuple(a)
load_dispatch[11] = (4, load_float)
def load_double(self, data):
a = array.array('d', data)
if self.prefix != byteorder:
a.byteswap()
return tuple(a)
load_dispatch[12] = (8, load_double)
def load_undefined(self, data):
return data
load_dispatch[7] = (1, load_undefined)
def load(self, fp):
self.reset()
i16 = self.i16
i32 = self.i32
for i in range(i16(fp.read(2))):
ifd = fp.read(12)
tag = i16(ifd)
typ = i16(ifd, 2)
if Image.DEBUG:
import TiffTags as TiffTags
tagname = TiffTags.TAGS.get(tag, 'unknown')
typname = TiffTags.TYPES.get(typ, 'unknown')
print 'tag: %s (%d)' % (tagname, tag), '- type: %s (%d)' % (typname, typ),
try:
dispatch = self.load_dispatch[typ]
except KeyError:
if Image.DEBUG:
print '- unsupported type', typ
continue
continue
(size, handler) = dispatch
size = size * i32(ifd, 4)
if size > 4:
here = fp.tell()
fp.seek(i32(ifd, 8))
data = ImageFile._safe_read(fp, size)
fp.seek(here)
else:
data = ifd[8:8 + size]
if len(data) != size:
raise IOError, 'not enough data'
self.tagdata[tag] = (typ, data)
if Image.DEBUG:
if tag in (COLORMAP, IPTC_NAA_CHUNK, PHOTOSHOP_CHUNK):
print '- value: <table: %d bytes>' % size
else:
print '- value:', self[tag]
tag in (COLORMAP, IPTC_NAA_CHUNK, PHOTOSHOP_CHUNK)
self.next = i32(fp.read(4))
def save(self, fp):
o16 = self.o16
o32 = self.o32
fp.write(o16(len(self.tags)))
tags = self.tags.items()
tags.sort()
directory = []
append = directory.append
offset = fp.tell() + len(self.tags) * 12 + 4
stripoffsets = None
for tag, value in tags:
if Image.DEBUG:
import TiffTags
tagname = TiffTags.TAGS.get(tag, 'unknown')
print 'save: %s (%d)' % (tagname, tag), '- value:', value
if type(value[0]) is type(''):
typ = 2
data = value = string.join(value, '\x00') + '\x00'
elif tag == STRIPOFFSETS:
stripoffsets = len(directory)
typ = 4
elif tag in (X_RESOLUTION, Y_RESOLUTION):
typ = 5
else:
typ = 3
for v in value:
if v >= 65536:
typ = 4
continue
if typ == 3:
data = string.join(map(o16, value), '')
else:
data = string.join(map(o32, value), '')
if len(data) == 4:
append((tag, typ, len(value), data, ''))
continue
if len(data) < 4:
append((tag, typ, len(value), data + (4 - len(data)) * '\x00', ''))
continue
count = len(value)
if typ == 5:
count = count / 2
append((tag, typ, count, o32(offset), data))
offset = offset + len(data)
if offset & 1:
offset = offset + 1
continue
if stripoffsets is not None:
(tag, typ, count, value, data) = directory[stripoffsets]
value = o32(self.i32(value) + offset)
directory[stripoffsets] = (tag, typ, count, value, data)
for tag, typ, count, value, data in directory:
if Image.DEBUG > 1:
print tag, typ, count, repr(value), repr(data)
fp.write(o16(tag) + o16(typ) + o32(count) + value)
fp.write('\x00\x00\x00\x00')
for tag, typ, count, value, data in directory:
fp.write(data)
if len(data) & 1:
fp.write('\x00')
continue
return offset
class TiffImageFile(ImageFile.ImageFile):
format = 'TIFF'
format_description = 'Adobe TIFF'
def _open(self):
ifh = self.fp.read(8)
if ifh[:4] not in PREFIXES:
raise SyntaxError, 'not a TIFF file'
self.tag = self.ifd = ImageFileDirectory(ifh[:2])
self._TiffImageFile__first = self._TiffImageFile__next = self.ifd.i32(ifh, 4)
self._TiffImageFile__frame = -1
self._TiffImageFile__fp = self.fp
self._seek(0)
def seek(self, frame):
if frame < 0:
frame = 0
self._seek(frame)
def tell(self):
return self._tell()
def _seek(self, frame):
self.fp = self._TiffImageFile__fp
if frame < self._TiffImageFile__frame:
self._TiffImageFile__frame = -1
self._TiffImageFile__next = self._TiffImageFile__first
while self._TiffImageFile__frame < frame:
if not self._TiffImageFile__next:
raise EOFError, 'no more images in TIFF file'
self.fp.seek(self._TiffImageFile__next)
self.tag.load(self.fp)
self._TiffImageFile__next = self.tag.next
self._TiffImageFile__frame = self._TiffImageFile__frame + 1
self._setup()
def _tell(self):
return self._TiffImageFile__frame
def _decoder(self, rawmode, layer):
args = None
if rawmode == 'RGB' and self._planar_configuration == 2:
rawmode = rawmode[layer]
compression = self._compression
if compression == 'raw':
args = (rawmode, 0, 1)
elif compression == 'jpeg':
args = (rawmode, '')
if self.tag.has_key(JPEGTABLES):
self.tile_prefix = self.tag[JPEGTABLES]
elif compression == 'packbits':
args = rawmode
elif compression == 'tiff_lzw':
args = rawmode
if self.tag.has_key(317):
self.decoderconfig = (self.tag[PREDICTOR][0],)
return args
def _setup(self):
if self.tag.has_key(48129):
raise IOError, 'Windows Media Photo files not yet supported'
getscalar = self.tag.getscalar
self._compression = COMPRESSION_INFO[getscalar(COMPRESSION, 1)]
self._planar_configuration = getscalar(PLANAR_CONFIGURATION, 1)
photo = getscalar(PHOTOMETRIC_INTERPRETATION, 0)
fillorder = getscalar(FILLORDER, 1)
if Image.DEBUG:
print '*** Summary ***'
print '- compression:', self._compression
print '- photometric_interpretation:', photo
print '- planar_configuration:', self._planar_configuration
print '- fill_order:', fillorder
xsize = getscalar(IMAGEWIDTH)
ysize = getscalar(IMAGELENGTH)
self.size = (xsize, ysize)
if Image.DEBUG:
print '- size:', self.size
format = getscalar(SAMPLEFORMAT, 1)
key = (photo, format, fillorder, self.tag.get(BITSPERSAMPLE, (1,)), self.tag.get(EXTRASAMPLES, ()))
if Image.DEBUG:
print 'format key:', key
try:
(self.mode, rawmode) = OPEN_INFO[key]
except KeyError:
if Image.DEBUG:
print '- unsupported format'
raise SyntaxError, 'unknown pixel mode'
if Image.DEBUG:
print '- raw mode:', rawmode
print '- pil mode:', self.mode
self.info['compression'] = self._compression
xdpi = getscalar(X_RESOLUTION, (1, 1))
ydpi = getscalar(Y_RESOLUTION, (1, 1))
if xdpi and ydpi and getscalar(RESOLUTION_UNIT, 1) == 1:
if not xdpi[1]:
pass
xdpi = xdpi[0] / 1
if not ydpi[1]:
pass
ydpi = ydpi[0] / 1
self.info['dpi'] = (xdpi, ydpi)
x = y = l = 0
self.tile = []
if self.tag.has_key(STRIPOFFSETS):
h = getscalar(ROWSPERSTRIP, ysize)
w = self.size[0]
a = None
for o in self.tag[STRIPOFFSETS]:
if not a:
a = self._decoder(rawmode, l)
self.tile.append((self._compression, (0, min(y, ysize), w, min(y + h, ysize)), o, a))
y = y + h
if y >= self.size[1]:
x = y = 0
l = l + 1
a = None
continue
elif self.tag.has_key(324):
w = getscalar(322)
h = getscalar(323)
a = None
for o in self.tag[324]:
if not a:
a = self._decoder(rawmode, l)
self.tile.append((self._compression, (x, y, x + w, y + h), o, a))
x = x + w
if x >= self.size[0]:
x = 0
y = y + h
if y >= self.size[1]:
x = y = 0
l = l + 1
a = None
y >= self.size[1]
elif Image.DEBUG:
print '- unsupported data organization'
raise SyntaxError('unknown data organization')
if self.mode == 'P':
palette = map((lambda a: chr(a / 256)), self.tag[COLORMAP])
self.palette = ImagePalette.raw('RGB;L', string.join(palette, ''))
SAVE_INFO = {
'1': ('1', 1, 1, (1,), None),
'L': ('L', 1, 1, (8,), None),
'LA': ('LA', 1, 1, (8, 8), 2),
'P': ('P', 3, 1, (8,), None),
'PA': ('PA', 3, 1, (8, 8), 2),
'I': ('I;32S', 1, 2, (32,), None),
'I;16': ('I;16', 1, 1, (16,), None),
'I;16S': ('I;16S', 1, 2, (16,), None),
'F': ('F;32F', 1, 3, (32,), None),
'RGB': ('RGB', 2, 1, (8, 8, 8), None),
'RGBX': ('RGBX', 2, 1, (8, 8, 8, 8), 0),
'RGBA': ('RGBA', 2, 1, (8, 8, 8, 8), 2),
'CMYK': ('CMYK', 5, 1, (8, 8, 8, 8), None),
'YCbCr': ('YCbCr', 6, 1, (8, 8, 8), None),
'LAB': ('LAB', 8, 1, (8, 8, 8), None) }
def _cvt_res(value):
if type(value) in (type([]), type(())):
return value
if type(value) == type(1):
return (value, 1)
value = float(value)
return (int(value * 65536), 65536)
def _save(im, fp, filename):
try:
(rawmode, photo, format, bits, extra) = SAVE_INFO[im.mode]
except KeyError:
raise IOError, 'cannot write mode %s as TIFF' % im.mode
ifd = ImageFileDirectory()
fp.write(ifd.prefix + ifd.o16(42) + ifd.o32(8))
ifd[IMAGEWIDTH] = im.size[0]
ifd[IMAGELENGTH] = im.size[1]
if hasattr(im, 'tag'):
for key in (RESOLUTION_UNIT, X_RESOLUTION, Y_RESOLUTION):
if im.tag.tagdata.has_key(key):
ifd[key] = im.tag.tagdata.get(key)
continue
if im.encoderinfo.has_key('description'):
ifd[IMAGEDESCRIPTION] = im.encoderinfo['description']
if im.encoderinfo.has_key('resolution'):
ifd[X_RESOLUTION] = ifd[Y_RESOLUTION] = _cvt_res(im.encoderinfo['resolution'])
if im.encoderinfo.has_key('x resolution'):
ifd[X_RESOLUTION] = _cvt_res(im.encoderinfo['x resolution'])
if im.encoderinfo.has_key('y resolution'):
ifd[Y_RESOLUTION] = _cvt_res(im.encoderinfo['y resolution'])
if im.encoderinfo.has_key('resolution unit'):
unit = im.encoderinfo['resolution unit']
if unit == 'inch':
ifd[RESOLUTION_UNIT] = 2
elif unit == 'cm' or unit == 'centimeter':
ifd[RESOLUTION_UNIT] = 3
else:
ifd[RESOLUTION_UNIT] = 1
if im.encoderinfo.has_key('software'):
ifd[SOFTWARE] = im.encoderinfo['software']
if im.encoderinfo.has_key('date time'):
ifd[DATE_TIME] = im.encoderinfo['date time']
if im.encoderinfo.has_key('artist'):
ifd[ARTIST] = im.encoderinfo['artist']
if im.encoderinfo.has_key('copyright'):
ifd[COPYRIGHT] = im.encoderinfo['copyright']
dpi = im.encoderinfo.get('dpi')
if dpi:
ifd[RESOLUTION_UNIT] = 1
ifd[X_RESOLUTION] = _cvt_res(dpi[0])
ifd[Y_RESOLUTION] = _cvt_res(dpi[1])
if bits != (1,):
ifd[BITSPERSAMPLE] = bits
if len(bits) != 1:
ifd[SAMPLESPERPIXEL] = len(bits)
if extra is not None:
ifd[EXTRASAMPLES] = extra
if format != 1:
ifd[SAMPLEFORMAT] = format
ifd[PHOTOMETRIC_INTERPRETATION] = photo
if im.mode == 'P':
lut = im.im.getpalette('RGB', 'RGB;L')
ifd[COLORMAP] = tuple(map((lambda v: ord(v) * 256), lut))
stride = len(bits) * ((im.size[0] * bits[0] + 7) / 8)
ifd[ROWSPERSTRIP] = im.size[1]
ifd[STRIPBYTECOUNTS] = stride * im.size[1]
ifd[STRIPOFFSETS] = 0
ifd[COMPRESSION] = 1
offset = ifd.save(fp)
ImageFile._save(im, fp, [
('raw', (0, 0) + im.size, offset, (rawmode, stride, 1))])
Image.register_open('TIFF', TiffImageFile, _accept)
Image.register_save('TIFF', _save)
Image.register_extension('TIFF', '.tif')
Image.register_extension('TIFF', '.tiff')
Image.register_mime('TIFF', 'image/tiff')